<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    span{
      display: inline-block;
      position: absolute;
      top: 120px;
      width: 50px;
      height: 50px;
      background-color: pink;
    }
  </style>
</head>
<body>
  <button>去500</button>
  <input type="button" value="去800" />
  <span></span>

  <script>
    function animate(obj, target, callback) {
      clearInterval(obj.timer)

      obj.timer = setInterval(function() {  
        // 如果 左边 =》 右   向上取整   Math.ceil
        // 目标位置 800  > 当前元素位置  =》 一定大于 0
        //  800             790  = 1
        //  800            799   = 1 = 0.1  =  0

        // 如果 右边 =》 左    向下取整   math.floor
        // 目标位置 500  < 当前元素位置  =》 一定小于 0
        //  500             510  = -1
        //  500            501   = -1 = -0.1  =    -1

        var step = (target - obj.offsetLeft) / 10
        step = step > 0 ? Math.ceil(step) : Math.floor(step)

        if( obj.offsetLeft == target ) {
          clearInterval(obj.timer)

          // if(callback) {
          //   callback()
          // }

          callback && callback()
        }

        obj.style.left = obj.offsetLeft + step + 'px'
      }, 30)
    }

    var span = document.querySelector('span')
    var btn = document.querySelector('button')
    var input = document.querySelector('input')

    btn.onclick = function() {
      animate(span, 500, function() {
        span.style.background = 'green'
      })
    }

    input.onclick = function() {
      animate(span, 800)
    }
  
    

  </script>
</body>
</html>